home *** CD-ROM | disk | FTP | other *** search
/ Languguage OS 2 / Languguage OS II Version 10-94 (Knowledge Media)(1994).ISO / gnu / libg_261.zip / libg_261 / libg++ / src / error.cc < prev    next >
C/C++ Source or Header  |  1994-09-01  |  2KB  |  59 lines

  1. /* 
  2. Copyright (C) 1990 Free Software Foundation
  3.     written by Doug Lea (dl@rocky.oswego.edu)
  4.  
  5. This file is part of the GNU C++ Library.  This library is free
  6. software; you can redistribute it and/or modify it under the terms of
  7. the GNU Library General Public License as published by the Free
  8. Software Foundation; either version 2 of the License, or (at your
  9. option) any later version.  This library is distributed in the hope
  10. that it will be useful, but WITHOUT ANY WARRANTY; without even the
  11. implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
  12. PURPOSE.  See the GNU Library General Public License for more details.
  13. You should have received a copy of the GNU Library General Public
  14. License along with this library; if not, write to the Free Software
  15. Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  16. */
  17.  
  18. #ifdef __GNUG__
  19. #pragma implementation
  20. #endif
  21. #include <builtin.h>
  22.  
  23. #ifdef __GNUC__
  24. typedef _VOLATILE_VOID (*NoReturnFunc)(void);
  25. /* Cast abort to a _VOLATILE_VOID function, even if <stdlib.h> differs.
  26. This is to avoid a warning from g++ that a `volatile' function does return. */
  27. #define ABORT() ((NoReturnFunc)abort)()
  28. #else
  29. #define ABORT() abort()
  30. #endif
  31.  
  32. _VOLATILE_VOID default_one_arg_error_handler(const char* msg)
  33. {
  34.   fputs("Error: ", stderr);
  35.   fputs(msg, stderr);
  36.   fputs("\n", stderr);
  37.   ABORT();
  38. }
  39.  
  40.  
  41. _VOLATILE_VOID default_two_arg_error_handler(const char* kind, const char* msg)
  42. {
  43.   fputs(kind, stderr);
  44.   fputs(" Error: ", stderr);
  45.   fputs(msg, stderr);
  46.   fputs("\n", stderr);
  47.   ABORT();
  48. }
  49.  
  50. two_arg_error_handler_t lib_error_handler = default_two_arg_error_handler;
  51.  
  52. two_arg_error_handler_t set_lib_error_handler(two_arg_error_handler_t f)
  53. {
  54.   two_arg_error_handler_t old = lib_error_handler;
  55.   lib_error_handler = f;
  56.   return old;
  57. }
  58.  
  59.